package com.wyr.leetcode.step1.tree;

public class MergeTreesTest {
    /**
     * 给你两棵二叉树： root1 和 root2 。
     *
     * 想象一下，当你将其中一棵覆盖到另一棵之上时，两棵树上的一些节点将会重叠（而另一些不会）。
     * 你需要将这两棵树合并成一棵新二叉树。合并的规则是：如果两个节点重叠，那么将这两个节点的值相加作为合并后节点的新值；
     * 否则，不为 null 的节点将直接作为新二叉树的节点。
     * 注意: 合并过程必须从两个树的根节点开始。
     *
     *
     * 输入：root1 = [1,3,2,5], root2 = [2,1,3,null,4,null,7]
     * 输出：[3,4,5,5,4,null,7]
     *
     * 返回合并后的二叉树。
     *
     * 来源：力扣（LeetCode）
     * 链接：https://leetcode.cn/problems/merge-two-binary-trees
     * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
     */
    //二叉树的题目大都是使用递归去写
    public TreeNode mergeTrees(TreeNode root1, TreeNode root2) {
        if(root1==null&&root2==null){
            return null;
        }
        if(root1!=null&&root2==null){
            return root1;
        }
        if(root1==null&&root2!=null){
            return root2;
        }

        TreeNode cur=new TreeNode(root1.val+root2.val);
        cur.left=mergeTrees(root1.left,root2.left);
        cur.right=mergeTrees(root1.right,root2.right);
        return cur;
    }


    public static class TreeNode {

        int val;
        TreeNode left;
        TreeNode right;

        TreeNode(int x) {
            val = x;
        }
    }

}
